草庐IT

HTTP、HTTPS、共享 SSL 和 SEO

全部标签

ruby - 在 AWS Linux 上增加 RestClient/Net::HTTP 中的 connect(2) 超时

我正在使用rest-client发布到一个非常慢的网络服务。我将timeout设置为600秒,并且我已经确认它正在传递给Net::HTTP的@read_timeout和@open_timeout.但是,大约两分钟后,我收到一个低级超时错误,Errno::ETIMEDOUT:Connectiontimedout-connect(2):回溯的相关部分是Operationtimedout-connect(2)for[myhost]port[myport]/Users/dmoles/.rvm/rubies/ruby-2.2.5/lib/ruby/2.2.0/net/http.rb:879:in

ruby - 我如何获得 RSpec 的共享示例,例如 Ruby Test::Unit 中的行为?

在RSpecforTest::Unittests中是否有类似于shared_examples的插件/扩展? 最佳答案 如果您正在使用rails(或只是active_support),请使用Concern.require'active_support/concern'moduleSharedTestsextendActiveSupport::Concernincludeddo#Thisway,testnamecanbeastring:)test'bananabananabanana'doasserttrueendendend如果您不使

解决错误LibreSSL SSL_connect: SSL_ERROR_SYSCALL in connection to

gitclone出现错误OpenSSLSSL_connect:SSL_ERROR_SYSCALLinconnectiontogithub.com:443升级node时错误OpenSSLSSL_connect:SSL_ERROR_SYSCALLinconnectiontonodejs.org:443解决方法以下几种解决方法可以尝试,由于开发环境不同,不一定每个都适用你的问题我用的mac电脑,方法一解决了我的问题,我先用的其它方法然而并没有解决方法一修改计算机网络配置由于使用IPv6的原因,可能会导致这一问题的出现系统在解析hostname时使用了ipv6可以配置计算机不使用IPv6,故使用以下命

ruby - SSL_connect returned=1 errno=0 state=SSLv3 read server hello A: 版本号错误 (OpenSSL::SSL::SSLError)

当我运行https.ssl_version=:TLSv1_2我得到了错误ruby/2.1.0/net/http.rb:920:in`connect':SSL_connectreturned=1errno=0state=SSLv3readserverhelloA:wrongversionnumber(OpenSSL::SSL::SSLError)当我更改为https.ssl_version=:SSLv3ruby/2.1.0/net/http.rb:920:in`connect':SSL_connectSYSCALLreturned=5errno=0state=SSLv3readserve

ruby - application 和 actioncable 不会共享 cookie

我正在使用devise进行身份验证,但是当我实现您的方法时,我得到“未经授权的连接尝试被拒绝”经过几个小时的搜索,我发现:cookies.signed['user.id']返回零。在以下代码块中。deffind_verified_userifverified_user=User.find_by(id:cookies.signed['user.id'])verified_userelsereject_unauthorized_connectionendend我查了一下,确实有cookie,但是里面没有Devise设置的cookie数据。为了检查“user.id”是否真的设置了,我在Vie

ruby - stub http 请求以返回带有 Net::HTTPResponse 的 HTTPartyResponse

我正在尝试编写一个rspec规范来测试我的逻辑是否能够处理状态代码为401的特定Net::HTTPResponse。当我使用HTTParty时,.get将返回一个HTTPartyResponse并且我'我们将使用httparty_repsonse_object.response检索Net::HTTPResponse。net_response_object=Net::HTTPResponse.new(1.1,401,'Forbidden')#notsurewhattodohere?writeatestdoubletoreturnanet_response_object?stub_requ

ruby - 为什么在 Net::HTTP 上使用 Faraday?

为什么有人会使用Faradaygem而不是直接使用Net::HTTP?使用这样的包装器有什么好处? 最佳答案 直接使用Net::HTTP适配器就可以了,它只是将您的代码绑定(bind)到一个特定的接口(interface),这可能与其他工具不同。人们会使用Faraday的主要原因是它包装了多个适配器,其中之一是Net::HTTP。如果您使用Faraday并开始使用Net:HTTP,您可以稍后决定使用Excon,Typhoeus,Patron或EventMachine无需更改超过一两行配置。如果您直接使用Net::HTTP,则必须更改

ruby - 如何让 ruby​​ 的 xmlrpc 客户端忽略 SSL 证书错误?

在ruby​​中使用xmlrpc/client访问XML-RPC服务时,如果服务器证书无效,它会抛出OpenSSL::SSL::SSLError。我怎样才能让它忽略这个错误并继续连接? 最佳答案 原来是这样的:xmlrpc=::XMLRPC::Client.new("foohost")xmlrpc.instance_variable_get(:@http).instance_variable_set(:@verify_mode,OpenSSL::SSL::VERIFY_NONE)这适用于ruby​​1.9.2,但显然是在探究内部结构

ruby - Net::HTTP 中的服务器名称指示支持?

我正在尝试让Ruby的Net::HTTP实现与SNI一起工作。mail.google.com和gmail.com都位于同一个IP地址上,因此当通过SSL连接时,Google服务器需要知道要使用哪个证书。默认情况下,它会返回mail.google.com证书,如果您尝试实现WebFinger,这就是一个问题。WebFinger要求您检索https://gmail.com/.well-known/host-meta以获取LRDD信息,但是,出于安全原因,验证SSL证书至关重要信息。由于Google在这种情况下提供默认的mail.google.com证书,因此SSLpost_connecti

ruby - 如何在 Node.js/RoR 中监控 20 个网站(Ping 或 HTTP)的正常运行时间

每5分钟(例如)ping20个网站的列表以了解该网站是否响应HTTP202的最佳方法是什么?最简单的想法是将20个URLS保存在数据库中,然后运行数据库并对每个URL执行ping操作。但是,当一个人不回答时会发生什么?之后的人会怎样?此外,是否有更好但更简单的解决方案?恐怕该列表会增长到20000个网站,然后没有足够的时间在我需要ping的5分钟内全部ping通它们。基本上,我是在描述PingDom、UptimeRobot等的工作原理。我正在使用node.js和RubyonRails构建这个系统。我也倾向于使用MongoDB来保存所有ping和监控结果的历史记录。建议?非常感谢!